Le choix du paquet GRUB à installer pour amorcer Ubuntu et les autres OS installés est dépendant du matériel et du type de partitionnement du disque dur.
Au niveau du matériel, pour les PC modernes, il existe deux modes de démarrage : le BIOS et l'UEFI, et deux principaux types d'architecture matérielle : la famille des x86 32 bits aussi nommée i386 ou IA-32, et les x86 64 bits aussi nommée AMD64 ou EMT64. Les architectures plus ancienne comme le PowerPC, ou plus récente comme l'ARM ne sont pas évoquée ici.
Pour ce qui est du partitionnement, qu'il soit sur le disque dur ou un autre suport (clé USB, carte SD), les deux principaux sont le type Intel qui utilise un MBR pour l'amorçage et le type GPT1) qui offre plusieurs possibilités.
L'ensemble de ces technologies pouvant être rencontrées indifféremment, cette page a pour but de vous guider dans vos paramétrages pour installer ou dépanner GRUB selon votre configuration matérielle.
Voir la page UEFI pour la modification du mode de démarrage et savoir dans quel mode est démarré Ubuntu.
A noter que Ubuntu 32 bits comme Ubuntu 64 bits peuvent démarré en mode UEFI même si ils n'ont pas été installé dans ce mode initialement.
Voir la page GPT.
Le tableau ci-dessous indique quel paquet GRUB doit être installé pour permettre l'amorçage en fonction de votre configuration :
| mode de démarrage | paquet GRUB | table de partition | commentaire | |
|---|---|---|---|---|
| BIOS/Legacy | grub-pc | Intel / MBR | Cas standard sur les configurations "anciennes". | |
| GPT | Nécessite une partition BIOS-boot. | |||
| UEFI | grub-efi | Intel / MBR | Le mode UEFI requiert une partition EFI (ou ESP2)) de type vfat. S'il n'est pas possible de créer une partition primaire supplémentaire, il est préférable de changer le mode de démarrage pour BIOS/Legacy. |
|
| GPT | Ubuntu 32 bits | Attention : si votre PC est de type x86-64 et que vous avez installé Ubuntu 32 bits, vous devez installer explicitement le paquet grub-efi-amd643) (voir Changer de version de GRUB) | ||
| SecureBoot | Pour la prise en charge de SecureBoot, il faut aussi installer le paquet shim et il est parfois nécessaire d'installer en plus les paquets signés par Microsoft : shim-signed et/ou grub-efi-amd64-signed | |||
Plusieurs version de GRUB ne peuvent pas cohabiter sur une même installation, donc si vous devez passer de grub-pc à grub-efi ou vice versa, il faut absolument désinstaller tout les paquets se rapportant à GRUB avant d'installer la version ciblée.
sudo apt-get remove grub*
sudo update-grub
trop d'info, pas clair, pas au bon endroit : faire un section Problème de boot : version GRUB installé incompatible
D'abord présenter le fonctionnement de GRUB sur BIOS/UEFI et MBR/EFI
Le live CD/USB d'Ubuntu 32 bits ne permet pas le démarrage en mode UEFI, mais il est possible de démarrer en mode BIOS/Legacy : la plupart des PC font ça automatiquement. Ainsi vous avez installé Ubuntu 32 bits et que votre système ne démarre plus après avoir retiré le CD ou la clé USB, vous êtes certainement en mode de démarrage UEFI par défaut et GRUB n'a pas été correctement installé.
Si votre disque dur a une table de partition Intel / MBR : Il suffit de modifier le réglage du BIOS/UEFI pour démarrer en mode Legacy. Lors de l'installation, Ubuntu a déjà dû installer grub-pc, sinon réinstaller-le via un chroot
Si votre disque dur a une table de partition GPT :
GRUB est constitué de 2 parties :
/etc/default/grub et les scripts situés dans /etc/grub.d.Dans cette configuration, le chargeur d'amorçage est placé dans un espace de 512 octet qui peut-être :
Schéma du disque :
| Début du disque | MBR7) | Partition primaire 1 | Partition primaire 2 | Partition primaire 3 | Partition étendue | Fin du disque | ||
|---|---|---|---|---|---|---|---|---|
| Partition logique 1 | … | Partition logique N | ||||||
| Device | /dev/sda | /dev/sda1 | /dev/sda2 | /dev/sda3 | /dev/sda5 | … | /dev/sda(4+N) | |
Exemple de partitionnement en présence de Windows :
| Emplacement du disque | Device | Point de montage | format | flag | commentaire | |
|---|---|---|---|---|---|---|
| MBR | sda | - | voir la page dédiée MBR | - | Contient la table des partitions primaires et étendues (jusqu'à 4 maximum) et le chargeur d'amorce GRUB. Pas de système de fichier, ne peut pas être monté |
|
| primaire 1 | sda1 | - | ntfs | - | Windows Loader | |
| primaire 2 | sda2 | /windowsou /mnt/windowsou /media/windows | ntfs | - | Windows OS | |
| étendue 1 | sda3 | - | - | extended | Contient la table des partitions logiques | |
| logique 1 | sda5 | / (racine) | ext4 | logical | Racine du système. Contient également /boot | |
| logique 2 | sda6 | none | swap | logical | Partition utilisée pour la swap | |
| logique 3 | sda7 | /home | ext4 | logical | Contient les données utilisateurs | |
Schéma du disque :
| Début du disque | Table GPT 1 | Protection MBR (inutilisé) | Partition BIOS boot (1Mo) | Partition 2 | Partition 3 | … | Partition N | Table GPT 2 | Fin du disque |
|---|---|---|---|---|---|---|---|---|---|
| Device | - | /dev/sda | /dev/sda1 | /dev/sda2 | /dev/sda3 | … | /dev/sdaN | - |
Exemple de partitionnement "classique" :
| Emplacement du disque | Device | Point de montage | format | flag | commentaire |
|---|---|---|---|---|---|
| Table GPT 1 | - | - | GPT | - | Inaccessible par fdisk. Utiliser l'outil gdisk. |
| MBR | sda | - | - | - | Espace du disque réservé pour empêcher tout écrasement avec les outils ne gérant que le partitionnement Intel/MBR |
| partition 1 | sda1 | - | non formaté (RAW) | BIOS boot | Contient le chargeur d'amorce GRUB |
| partition 2 | sda2 | / (racine) | ext4 | - | Racine du système. Contient également /boot |
| partition 3 | sda3 | none | swap | - | Partition utilisée pour la swap |
| partition 4 | sda4 | /home | ext4 | - | Contient les données utilisateurs |
| Table GPT 2 | - | - | GPT | - | Copie de sauvegarde de la table GPT 1. (optionnel) |